101. 101010110001001000110100010101101 

102. 101010110001001000110100010101110 

103. 101010110001001000110100010101100 

1 04. 10101011 0001 001 0001 1 01 0001 01 01 000 

1 05. 1 01 01 01 1 0001 001 0001 1 01 0001 01 1 0000 

1 06. 10101011 0001 001 0001 1 01 0001 01 00000 

1 07. 10101011 0001 001 0001 1 01 0001 1 000000 

1 08. 10101011 0001 001 0001 1 01 0001 0000000 

1 09. 1 01 01 01 1 0001 001 0001 1 01 001 00000000 

110. 1 01 01 01 1 0001 001 0001 1 01 01 000000000 

111. 1 01 01 01 1 0001 001 0001 1 01 1 0000000000 

112. 1 01 01 01 1 0001 001 0001 1 01 00000000000 

113. 1 01 01 01 1 0001 001 0001 1 1 000000000000 

114. 1 01 01 01 1 0001 001 0001 1 0000000000000 

115. 10101011 0001 001 0001 00000000000000 

116. 1 01 01 01 1 0001 001 001 000000000000000 

117. 1 01 01 01 1 0001 001 01 0000000000000000 

118. 1 01 01 01 1 0001 001 1 00000000000000000 

119. 10101011 0001 001 000000000000000000 

120. 10101011 0001 01 0000000000000000000 

121. 1 01 01 01 1 0001 1 00000000000000000000 

122. 1010101 10001000000000000000000000 

123. 1 01 01 01 1 001 0000000000000000000000 

1 24. 1 010101 1 01 00000000000000000000000 

1 25. 101010111 000000000000000000000000 

1 26. 10101011 0000000000000000000000000 

1 27. 1 01 01 01 00000000000000000000000000 

128. 101011 000000000000000000000000000 

1 29. 1 01 01 0000000000000000000000000000 

1 30. 1011 00000000000000000000000000000 

131 . 1 01 000000000000000000000000000000 

1 32. 11 0000000000000000000000000000000 



Figure 1 (Prior Art) 
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Packet Forwarding/Routing Processing 
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Longest Match Search Processing 
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Receive a new search key 
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Figure 5 



Apply the query to the routing table 
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Longest Match Search Processing 
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Receive a new 
SearchKey 



Index = SearchKey[31:16] 
Maskword = MaskTable[index] 




730 



Mask[0] = MaskWord[0] 
Mask[1] = MaskWord[1] || Mask[0] 
Mask[2] = MaskWord[2] || Mask[1] 

Mask[31] = MaskWord[31] || Mask[30] 
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EndBit = ~ ( Mask * 2 ) & Mask 
Query = ( ( SearchKey & Mask ) * 2 ) | EndBit 
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MaskWord = 
( mask * 2 ) & 
MaskWord 
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MaskWord 


0001000100010000 


0 - MaskWord 


1110111011110000 


Mask 


1111111111110000 
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MaskWord 


0001000100010000 


Mask 


1111111111110000 


Mask * 2 


1111111111100000 


New MaskWord 


0001000100000000 
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